package com.itheima.dao;
import com.github.pagehelper.Page;
import com.itheima.pojo.Setmeal;

import java.util.List;
import java.util.Map;
/**
 * @author chenxys
 * @Description: 套餐接口
 * @date 2022/5/22 15:07
 */
public interface SetMealDao {
    /**
     * 分页查询
     * @author chenxys
     * @param queryString
     * @return com.github.pagehelper.Page<com.itheima.pojo.Setmeal>
     */
    Page<Setmeal> pageQuery(String queryString);
    /**
     * 添加检查套餐
     * @author chenxys
     * @param setmeal
     * @return void
     */
    void add(Setmeal setmeal);
    /**
     * 设置检查套餐与检查组的关系
     * @author chenxys
     * @param map
     * @return void
     */
    void setCheckGroupAndSetMeal(Map<String, Integer> map);
    /**
     * 查询当前套餐与订单是否有关联
     * @author chenxys
     * @param id
     * @return java.lang.Long
     */
    Long findCountBySetMealId(Integer id);
    /**
     * 根据ID删除套餐
     * @author chenxys
     * @param id
     * @return void
     */
    void deleteById(Integer id);
    /**
     * 删除与检查组的关联关系
     * @author chenxys
     * @param id
     * @return void
     */
    void deleteCheckGroupAndSetMealById(Integer id);
    /**
     * 根据套餐ID查询套餐信息
     * @author chenxys
     * @param id
     * @return com.itheima.pojo.Setmeal
     */
    Setmeal findById(Integer id);
    /**
     * 根据套餐ID查询检查组信息
     * @author chenxys
     * @param id
     * @return java.util.List<java.lang.Integer>
     */
    List<Integer> findCheckGroupBySetMealId(Integer id);
    /**
     * 根据检查套餐ID删除原有关联关系
     * @author chenxys
     * @param id
     * @return void
     */
    void deleteAssociation(Integer id);
    /**
     * 修改检查套餐
     * @author chenxys
     * @param setmeal 套餐
     * @return void
     */
    void edit(Setmeal setmeal);
    /**
     * 查询所有套餐信息
     * @author chenxys
     * @return java.util.List<com.itheima.pojo.Setmeal>
     */
    List<Setmeal> findAll();
    /**
     * 根据套餐ID查询套餐[基本信息+检查套组信息+检查项信息]
     * @author chenxys
     * @param id 套餐ID
     * @return com.itheima.pojo.Setmeal
     */
    Setmeal findByIds(Integer id);
    /**
     * 获取预约套餐名称和预约次数
     * @author chenxys
     * @return java.util.List<java.util.Map<java.lang.String,java.lang.Object>>
     */
    List<Map<String, Object>> findSetmealCount();
}
